<?php

require_once __DIR__ . '/../vendor/autoload.php';

(
    new Laravel\Lumen\Bootstrap\LoadEnvironmentVariables(
        dirname(__DIR__)
    )
)->bootstrap();

date_default_timezone_set(env('APP_TIMEZONE', 'PRC'));

/*
|--------------------------------------------------------------------------
| Create The Application
|--------------------------------------------------------------------------
|
| Here we will load the environment and create the application instance
| that serves as the central piece of this framework. We'll use this
| application as an "IoC" container and router for this framework.
|
*/

$app     = new Laravel\Lumen\Application(
    dirname(__DIR__)
);
$aliases = [
    Intervention\Image\Facades\Image::class => 'Image'
];

$app->withFacades(true, $aliases);

$app->withEloquent();

/*
|--------------------------------------------------------------------------
| Register Container Bindings
|--------------------------------------------------------------------------
|
| Now we will register a few bindings in the service container. We will
| register the exception handler and the console kernel. You may add
| your own bindings here if you like or you can make another file.
|
*/

$app->singleton(
    Illuminate\Contracts\Debug\ExceptionHandler::class,
    App\Exceptions\Handler::class
);

$app->singleton(
    Illuminate\Contracts\Console\Kernel::class,
    App\Console\Kernel::class
);

/*
|--------------------------------------------------------------------------
| Register Config Files
|--------------------------------------------------------------------------
|
| Now we will register the "app" configuration file. If the file exists in
| your configuration directory it will be loaded; otherwise, we'll load
| the default version. You may register other files below as needed.
|
*/
$app->configure('swagger-lume');
//附件配置
$app->configure('attachment');
$app->configure('filesystems');
// $app->configure('swoole_http');
// $app->configure('swoole_websocket');
$app->configure('laravel-model-caching');
$app->configure('app');

/*
|--------------------------------------------------------------------------
| Register Middleware
|--------------------------------------------------------------------------
|
| Next, we will register the middleware with the application. These can
| be global middleware that run before and after each request into a
| route or middleware that'll be assigned to some specific routes.
|
*/

$app->middleware([
    App\Http\Middleware\FormaterResponse::class,

]);

$app->routeMiddleware([
    'auth'                 => App\Http\Middleware\Authenticate::class,
    'permission.parameter' => App\Http\Middleware\Permission::class,
    // 'formatterJson' => App\Http\Middleware\FormaterResponse::class
]);

/*
|--------------------------------------------------------------------------
| Register Service Providers
|--------------------------------------------------------------------------
|
| Here we will register all of the application's service providers which
| are used to bind services into the container. Service providers are
| totally optional, so you are not required to uncomment this line.
|
*/

$app->register(Illuminate\Redis\RedisServiceProvider::class);
$app->register(\SwaggerLume\ServiceProvider::class);
//增加lumen命令
// $app->register(Flipbox\LumenGenerator\LumenGeneratorServiceProvider::class);
$app->register(App\Providers\AppServiceProvider::class);

$app->register(App\Providers\AuthServiceProvider::class);
 
$app->register(App\Providers\MiniProServiceProvider::class);
// $app->register(\MigrationsGenerator\MigrationsGeneratorServiceProvider::class);
$app->register(GeneaLabs\LaravelModelCaching\Providers\Service::class);
// $app->register(SwooleTW\Http\LumenServiceProvider::class);
// $app->register(Hhxsv5\LaravelS\Illuminate\LaravelSServiceProvider::class);
$app->register(App\Providers\EventServiceProvider::class);
$app->register(Intervention\Image\ImageServiceProvider::class);
$app->register(App\Providers\ValidatorServiceProvider::class);
$app->register(Maatwebsite\Excel\ExcelServiceProvider::class);
//钉钉服务提供者
$app->register(App\Providers\DingTalkServiceProvider::class);

// $app->register(Prettus\Repository\Providers\LumenRepositoryServiceProvider::class);
/*
|--------------------------------------------------------------------------
| Load The Application Routes
|--------------------------------------------------------------------------
|
| Next we will include the routes file so that they can all be added to
| the application. This will provide all of the URLs the application
| can respond to, as well as the controllers that may handle them.
|
*/

$app->router->group([
    'namespace' => 'App\Http\Controllers',
], function ($router)
    {
    require __DIR__ . '/../routes/web.php';
    });

return $app;